/*
 * Copyright 2013 University of Padua, Italy
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package it.dei.unipd.healthservice.servlet;

import it.dei.unipd.healthservice.database.CreateRecapitoDatabase;
import it.dei.unipd.healthservice.resource.Recapito;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.SQLException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Esempio di servlet per inserire dati in un database.
 * 
 * @author Nicola Salmaso
 * @version 1.00
 */
public class CreateRecapitoServlet extends AbstractDatabaseServlet {
	/**
	 * Crea un nuovo impiegato.
	 * 
	 * @param req
	 *            la richiesta ricevuta dal client.
	 * @param res
	 *            la rispota fornita dal server.
	 * 
	 * @throws ServletException
	 *             se ci sono problemi nell'esecuzione della servlet.
	 * @throws IOException
	 *             se ci sono problemi nella comunicazione client-server.
	 */
	public void doPost(HttpServletRequest req, HttpServletResponse res)
			throws ServletException, IOException {

		// imposta il tipo MIME della risposta
		res.setContentType("text/html");

		// ottiene un flusso di uscita per scrivere la risposta
		PrintWriter out = res.getWriter();

		Integer idRecapito=0;//Integer.parseInt(req.getParameter("nome"));
		String ragione_sociale = req.getParameter("ragione_sociale");
		String stato = req.getParameter("stato");
		String provincia = req.getParameter("provincia");
		String citta = req.getParameter("citta");
		String indirizzo = req.getParameter("indirizzo");
		String cap = req.getParameter("cap");
		Recapito recapito=new Recapito(ragione_sociale,stato,provincia,citta,indirizzo,cap);
		String mail = new CarrelloServlet().getCarrello(req, res).getEmail();
		Connection con = null;

		// scrive la pagina HTML
		out.printf("<html>%n");
		out.printf("<head><title>Crea un nuovo recapito</title></head>%n");
		out.printf("<body>%n");
		out.printf("<h1>Riepilogo creazione del recapito</h1>");

		try {
			con = DS.getConnection();

			idRecapito = new CreateRecapitoDatabase(con,recapito,mail).createRecapito();
			out.println("Operazione riuscita");
			

		} catch (NullPointerException ex) {
			out.printf("<p><center><font color=\"red\" size=\"+2\">Impossibile creare la connessione al database.</font></center></p>");
		} catch (SQLException ex) {
			out.printf(
					"<p><center><font color=\"red\" size=\"+2\">Errore durante l'accesso al database: %s</font></center></p>",
					ex.getMessage());
		}

		//out.println("Operazione riuscita");
		out.printf("</body></html>");

		// assicura che tutto il contenuto sia inviato
		out.flush();

		// chiude il flusso di uscita
		out.close();

	}

}
